package com.gjx.leetcode;

//114. 二叉树展开为链表
//
//给定一个二叉树，原地将它展开为链表。
//
//例如，给定二叉树
//
//    1
//   / \
//  2   5
// / \   \
//3   4   6
//将其展开为：
//
//1
// \
//  2
//   \
//    3
//     \
//      4
//       \
//        5
//         \
//          6

public class Solution114 {
	public void flatten(TreeNode root) {
		if (root == null) {
			return;
		}
		
		flatten(root.left);
		flatten(root.right);
		
		if (root.left != null) {
			TreeNode left = root.left;
			root.left = null;
			
			TreeNode p = left;
			
			while (p.right != null) {
				p = p.right;
			}
			p.right = root.right;
			root.right = left;
		}
		
	}
}
